package org.dromara.system.service;

import org.dromara.system.domain.vo.StoreVo;
import org.dromara.system.domain.bo.StoreBo;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery;

import java.util.Collection;
import java.util.List;

/**
 * 店铺信息Service接口
 *
 * @author joker
 * @date 2025-05-05
 */
public interface IStoreService {

    /**
     * 查询店铺信息
     *
     * @param storeId 主键
     * @return 店铺信息
     */
    StoreVo queryById(Long storeId);

    /**
     * 分页查询店铺信息列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 店铺信息分页列表
     */
    TableDataInfo<StoreVo> queryPageList(StoreBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的店铺信息列表
     *
     * @param bo 查询条件
     * @return 店铺信息列表
     */
    List<StoreVo> queryList(StoreBo bo);

    /**
     * 新增店铺信息
     *
     * @param bo 店铺信息
     * @return 是否新增成功
     */
    Boolean insertByBo(StoreBo bo);

    /**
     * 修改店铺信息
     *
     * @param bo 店铺信息
     * @return 是否修改成功
     */
    Boolean updateByBo(StoreBo bo);

    /**
     * 校验并批量删除店铺信息信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
}
